package com.atguigu.lease.web.app.mapper;

import com.atguigu.lease.model.entity.RoomInfo;
import com.atguigu.lease.web.app.vo.room.RoomItemVo;
import com.atguigu.lease.web.app.vo.room.RoomQueryVo;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import org.apache.ibatis.annotations.Mapper;

import java.math.BigDecimal;

/**
 * @author liubo
 * @description 针对表【room_info(房间信息表)】的数据库操作Mapper
 * @createDate 2023-07-26 11:12:39
 * @Entity com.atguigu.lease.model.entity.RoomInfo
 */
@Mapper
public interface RoomInfoMapper extends BaseMapper<RoomInfo> {

    /**
     * 分页查询房间列表
     *
     * @param page    分页信息
     * @param queryVo 查询条件
     * @return 当前页信息
     */
    IPage<RoomItemVo> selectRoomItemVoListByQuery(Page<RoomItemVo> page, RoomQueryVo queryVo);

    /**
     * 公寓房间最低租金
     *
     * @param id 公寓id
     * @return 最低租金
     */
    BigDecimal selectMinRentByApartmentId(Long id);

    /**
     * 根据公寓id分页查询房间列表
     *
     * @param current 当前页
     * @param size    每页大小
     * @param id      公寓id
     * @return 当前页房间的信息
     */
    IPage<RoomItemVo> selectRoomItemVoListByQueryAndApartmentId(Page<Object> objectPage, Long id);
}